草庐IT

java - 单个字符串

全部标签

ruby 和重音字符

下面的文字摘要:如何在Ruby中显示重音字符(以便它们通过puts等工作)?您好!我正在为我的类(class)编写一个程序,它将用西类牙语显示一些句子。当我尝试在Ruby中使用重音字符时,它们无法正确显示(在NetBeans输出窗口(在Java中可以正常显示重音字符)或在命令提示符中)。起初,我的一些代码甚至没有运行,因为我的数组中的重音字符抛出了Ruby中断器(我猜?)。我遇到错误,例如Ruby需要一个右括号。但我做了一些研究,找到了一个解决方案,将以下代码行添加到我的Ruby文件的开头:#编码:utf-8在NetBeans中,我的程序运行与这一行无关。但我需要添加这一行才能让我的程

ruby - 如何制作 Ruby 1.8 小写非拉丁字符?

我正在使用Ruby1.8。似乎downcase不会改变非拉丁字符。例如:"Δ".downcase返回“Δ”我知道在Ruby1.9.1及更高版本中,我可以使用UnicodeUtils(fromhere)。我试过了,它工作正常。返回上一个示例的"δ"。是否有适用于1.8Ruby的等效(或任何)解决方案? 最佳答案 nash@nash:~$ruby-vruby1.8.7(2011-02-18patchlevel334)[i686-linux]gem安装unicode(https://rubygems.org/gems/unicode)re

ruby - 错误的参数类型字符串(应为数组)

我正在尝试使用Octopress(Jekyll之上的博客引擎)在我的新Macbook上,当我运行bundleexecjekyll--server时出现此错误:(缩短路径)/path/to/markdown.rb:118:in`to_html':wrongargumenttypeString(expectedArray)(TypeError)from/path/to/markdown.rb:118:in`convert'...(完整路径)/usr/local/rvm/gems/ruby-1.9.2-p290/gems/jekyll-0.11.0/lib/jekyll/converters

ruby-on-rails - 如何使 Rails 3 JSON 解析双引号字符串和单个数字

背景关于json.org网站,字符串定义为"char+",其中char+是一个或多个char。char是除"或\之外的任何unicode字符。控制字符的子集是允许的,只需将它们转义即可:“foo”“2”“\\”在Javascript中,如果要解析一个字符串,需要将其括起来:"\"foo\""或'"foo"',但不是"'foo'"在Rails3中,JSONgem默认运行C或纯Ruby代码。根据接受的答案,gem解析JSON文档而不是元素。文档是键、值(对象/哈希)或值(数组)形式的集合。问题字符串假设我们要解析字符串foo,我们需要将其括为"\"foo\""或'"foo"'JSON.pa

ruby-on-rails - RSpec 中单个设置的多个断言

我想优化一些较慢的规范。此类规范的示例如下所示:require'rspec'classHeavyComputationdefcompute_resultsleep1#somethingcomputeheavyhere"verybigstring"endenddescribeHeavyComputation,'preferredstyle,butslow'dosubject{described_class.new.compute_result}it{shouldinclude'big'}it{shouldmatch'string'}it{shouldmatch/very/}#+50oth

ruby - 从 ruby​​ 中的多个线程写入单个文件

我正在尝试从多个线程写入单个文件。我遇到的问题是,在程序退出之前,我看不到任何内容被写入文件。 最佳答案 你需要file.flush来写出来。您还可以设置file.sync=true使其自动刷新。 关于ruby-从ruby​​中的多个线程写入单个文件,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2761517/

ruby - Ruby 中更快的常量时间字符串比较

我正在尝试将用户提供的身份验证token与存储在我的服务器上的身份验证token进行比较。最明显的方法就是使用==,但这可能会造成定时攻击。为了缓解这种情况,我编写了这个安全比较函数:#stringcomparisonthatleaksnoinformationaboutthestrings.#looselybasedonhttps://github.com/rack/rack/blob/master/lib/rack/utils.rb#andhttp://security.stackexchange.com/questions/49849/timing-safe-string-com

ruby - Ruby 中的字符串编码

我最近开始使用Ruby进行编码,对某些行为感到困惑。我正在使用2.2.3p173并显示以下内容:__ENCODING__#=>#Defaultencodingin2.2.3"my_string".encoding#=>#Object.to_s.encoding#=>#Object.new.to_s.encoding#=>#这种编码差异的原因是什么? 最佳答案 不错的发现!简短的回答是它完全是任意的,它取决于Ruby如何在内部构建返回的字符串。有一大堆内部C函数可以使用US-ASCII编码构造空字符串或文字字符串:rb_usascii

ruby - 打包的 Ruby 字符串中的奇怪行为

我对某些ruby​​行为感到困惑。看下面的代码:[127].pack("C")=="\x7f"#=>true这是有道理的。现在:[128].pack("C")#=>"\x80""\x80"#=>"\x80"[128].pack("C")=="\x80"#=>falsepackoption"C"代表8-bitunsigned(unsignedchar),应该可以存储128的值。两个字符串也打印相同的东西,那么为什么它们不相等呢?这与编码有关吗?我使用的是ruby​​2.0.0p247。 最佳答案 这是错误的,因为编码不同:[128].

ruby - 为什么关键字参数必须作为带有符号键的散列传递,而不是 Ruby 中的字符串键?

我们不能将关键字参数作为带有字符串键的散列传递,关键字参数仅适用于作为符号键的散列。一个简单的例子:defmy_method(first_name:,last_name:)puts"first_name:#{first_name}|last_name:#{last_name}"endmy_method({last_name:'Sehrawat',first_name:'Manoj'})#=>first_name:Manoj|last_name:Sehrawatmy_method({first_name:'Bob',last_name:'Marley'})#=>first_name:Bo